草庐IT

Python Docstring : raise vs. 引发

全部标签

ruby - 延迟作业每次引发错误时都会创建空气制动器

defperformrefund_log={success:refund_retry.success?,amount:refund_amount,action:"refund"}ifrefund_retry.success?refund_log[:reference]=refund_retry.transaction.idrefund_log[:message]=refund_retry.transaction.statuselserefund_log[:message]=refund_retry.messagerefund_log[:params]={}refund_retry.er

ruby - 在 Ruby 中,对于 undefined variable "foo",为什么 "foo = foo"不引发错误?

当foo是一个undefinedvariable时,试图访问它会引发一个NameError:foo#=>NameError:undefinedlocalvariableormethod`foo'a=foo#=>NameError:undefinedlocalvariableormethod`foo'为什么foo=foo不引发NameError?foo=foo#=>nil昨天,我花了几个小时才将这一行作为程序中的错误来追踪......capture=capture.to_i我本来打算做的是将capture_str转换为Integer。我所做的是通过说capture=capture来引入n

ruby-on-rails - 为什么 `rake db:drop` 失败时退出状态为 0,并且不引发错误?

我惊讶地发现,当rakedb:drop(假设是Rails的其他内置raketasks)失败时,bash状态代码为0。$rakedb:dropcouldnotconnecttoserver:ConnectionrefusedIstheserverrunningonhost"localhost"(::1)andacceptingTCP/IPconnectionsonport5432?...$echo$?0也许更令人惊讶的是,当从Rails中调用任务时,它甚至不会引发错误。2.3.0:001>begin2.3.0:002>Rake::Task["db:drop"].invoke2.3.0:0

ruby-on-rails - 为什么 Ruby on Rails 在编辑代码后会虚假地引发 0​​x104567910?

在我的Ruby(2.3.0)onRails(5.0.1)项目中,自动加载(和重新加载)通常工作正常。但是,在开发模式下,我偶尔会看到如下错误:UnabletoautoloadconstantFoo::Bar,expected/app/models/foo/bar.rbtodefineit这是出乎意料的,因为:第一个请求运行良好(已经自动加载一次)。它仅在编辑代码并发送新请求后出现。它并不总是会发生。我不明白为什么有时无法重新加载。文件(foo/bar.rb)实际上定义了Foo::Bar。此外,foo/bar.rb的代码非常简单:moduleFooclassBar简单的解决方法是重新启动

ruby-on-rails - YAML::load 引发未定义的类/模块错误

我正在我的Rails应用程序中实现类似文件跟踪的功能。为此,我在YAML中序列化对象。我有item_at_version方法,它基本上执行YAML::load(cached_object)–这工作得很好,但是,我不知道为什么,有时它返回未定义的类/模块_类名_。它适用于Event、Conversation、Note等模型,但没有任何理由,它似乎会为Dataset、Comment、Student等模型抛出该错误(我试图找到任何模式,但没有任何运气).我正在使用rails3.2.8、ruby1.9.3p327、psych作为YAML引擎(Psych::Version返回1.3.4)。附言。

ruby - Rspec any_instance.stub 为 nil :NilClass exception 引发未定义的方法 `any_instance_recorder_for'

这是我正在测试的包含在Foo.rb中的类:classFoodefbarreturn2endend这是Foo_spec.rb中包含的我的测试:require"./Foo.rb"describe"Foo"dobefore(:all)doputs"#{Foo==nil}"Foo.any_instance.stub(:bar).and_return(1)endit"shouldpassthis"dof=Foo.newf.bar.shouldeq1endend我得到以下输出:falseFFailures:1)FooShouldpassthisFailure/Error:Foo.any_insta

ruby - Ruby 2.2 中的垃圾收集器引发意想不到的 CoW

当我fork我的进程时,如何防止GC引发写时复制?由于我在我的程序中遇到了一些内存问题(我的60核0.5Tb机器上的内存不足,即使是相当小的任务),我最近一直在分析Ruby中垃圾收集器的行为。对我来说,这确实限制了ruby​​在多核服务器上运行程序的实用性。我想在这里展示我的实验和结果。当垃圾收集器在fork期间运行时会出现此问题。我调查了三个案例来说明这个问题。案例一:我们使用数组在内存中分配了很多对象(不超过20字节的字符串)。字符串是使用随机数和字符串格式创建的。当进程fork并且我们强制GC在子进程中运行时,所有共享内存都变为私有(private),导致初始内存重复。案例2:我

ruby - 是否有可能获得引发错误的行号?

begin...#erroroccurshere...rescue=>errorputs"Error:"+error.messageend有没有办法获取发生错误的语句的行号? 最佳答案 只需要回溯:begin...#erroroccurshere...rescue=>errorputs"Error:"+error.messageputserror.backtraceend要仅获取行号-只需通过正则表达式将其从回溯中解析出来即可。可在此处找到更多信息:Catchinglinenumbersinrubyexceptions

ruby-on-rails - Rspec - 引发错误时参数数量错误

所以在我的代码中我尝试测试这个方法:#checksifafilealreadyexistsonS3deffile_exists?(storage_key)begins3_resource.bucket(@bucket).object(storage_key).exists?rescueAws::S3::Errors::Forbidden=>efalseendend现在我正在尝试制作两个测试用例-一个用于文件存在的情况,一个用于文件不存在的情况。关注失败案例。我想去掉exists?提高Aws::S3::Errors::Forbidden错误使得file_exists?方法将返回false

ruby-on-rails - ruby 更新到 2.5.0 后,需要 'bundler/setup' 引发异常

在ruby​​2.5.0更新后从Rails应用程序调用rake,不起作用。$rakeTraceback(mostrecentcalllast):22:from./bin/rake:4:in`'21:from./bin/rake:4:in`require_relative'20:from/Users/user/work/hw/relocations_app/config/boot.rb:5:in`'19:from/Users/user/.rvm/rubies/ruby-2.5.0/lib/ruby/2.5.0/rubygems/core_ext/kernel_require.rb:39: